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Method and Apparatus for Combining Parts of Different Web Pages 

BACKGROUND OF THE INVENTION 
5 The present invention relates generally to computer networks and, specifically, to a 

method and apparatus that allow users to select certain portions of web pages to form "short" 
web pages. 

The expanded popularity of the World Wide Web ("the web") has brought new 
problems for web users. As users obtain more and more information from the web, they must 

10 visit greater numbers of different web pages to obtain the information. This information is 
often contained on several separate web pages or web sites. Alternately, a user may wish to 
see only a small piece of information that is contained in a very large and complex page or 
site. The user must search through the pages in which he is not interested to reach the 
information that he wishes to see. 

1 5 Many users visit the same sequence of web pages or sites on a daily or a regular basis. 

For example, some users might check the weather or their stock portfolio on a daily basis. 
Even though a user may visit the same web pages and/or sites regularly, the user must still 
take individual actions to visit each of his regularly visited web pages or sites. For example, 
the user may have to enter the web addresses of each page or click on each page in a list of 

20 saved addresses in his browser. This repeated entry of web addresses is time consuming and 
involves un-needed repetitive action by the user. 

What is needed is a way to avoid regularly re-entering the same multiplicity of web 
addresses and a way to avoid having to navigate through multi-level web sites to reach 
desired information. 

25 

SUMMARY OF THE INVENTION 

A described embodiment of the present invention allows users to select certain sub- 
elements of web pages for later viewing. The user can use any of a wide variety of client 
devices to view the web page, such as a computer, a handheld device, or a cell phone. When 
30 the user views the shortened web page at a later time, only the sub-elements of the web page 
selected by the user are displayed. Thus, the user views only preselected sub-elements of the 
web page. 
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A further aspect of the described embodiment allows users to select certain sub- 
elements of multiple web pages or sites as part of a web page. The user's selection 
information is saved and, when at a later time, only the sub-elements of the web pages and/or 
sites indicated by the user are displayed for viewing by the user. Thus, the user views only 
5 preselected sub-elements of the web pages or sites. In the described embodiment, a page 
based on multiple web pages or sites is called a "combopage" (short for "combination page") 
and is based on a combination of selection information from single pages or sites. Other 
embodiments of combopages need not be based on combination of selection information for 
single pages. 

10 Multiple users can share a short page. Such a shared shortpage or combopage is 

called a shared portal. For example, multiple users can place information on a short page or 
combo page. Alternately, multiple users can view a shortpage or combopage created by a 
third party or third parties. 

In accordance with the purpose of the invention, as embodied and broadly described 

15 herein, the invention relates to a method for creating a combination web page, comprising: 
allowing a user to choose a subset of elements, some of which appear on a first web page and 
some of which appear on a second web page; saving the user's choices; and creating a 
combination web page that is based on the first web page and the second web page, and 
includes the elements chosen by the user in accordance with the user's saved choices. 

20 In further accordance with the purpose of the invention, as embodied and broadly 

described herein, the invention relates to a method for creating a combination web page, 
comprising: storing in a memory selection information specifying the elements on a 
combination web page, the combination web page being based on at least two original web 
pages; retrieving the original web pages upon which the combination web page is based; and 

25 creating the combination web page from elements on the original web pages in accordance 
with the selection information. 

In further accordance with the purpose of the invention, as embodied and broadly 
described herein, the invention relates to a computer-implemented method performed by a 
server data processing system, comprising: receiving, from a client, a request for multiple 

30 web pages; retrieving the multiple web pages; sending the requested multiple web pages to 
the client; receiving, from the client, selection information for the requested multiple web 
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pages, the selection information indicating a subset of the information of the web pages that is 
smaller than the set of all information on the web pages; and storing the selection information 
in the server data processing system. 

In further accordance with the purpose of the invention, as embodied and broadly 
5 described herein, the invention relates to a computer-implemented method performed by a 
server data processing system, comprising: receiving, from a client, a request for a user's 
combination web page; retrieving at least two web pages upon which the user's combination 
web page is based; selecting portions of the retrieved web pages in accordance with selection 
information of the user stored in the server data processing system; and sending the user's 

10 combination page, containing the selected portions of the retrieved web page to the user. 

In further accordance with the purpose of the invention, as embodied and broadly 
described herein, the invention relates to a computer-implemented method performed by a 
client data processing system, comprising: sending, by a client, a request for at least two web 
pages; receiving the requested web pages; allowing the user to select portions of the received 

1 5 web pages as being hidden or shown, the hidden portions being indicated by selection 

information; and sending, to a server, the selection information for a combination web page 
formed by the at least two web pages. 

In further accordance with the purpose of the invention, as embodied and broadly 
described herein, the invention relates to an apparatus that creates a combination web page, 

20 comprising: software portions configured to allow a user to choose a subset of elements, 
some of which appear on a first web page and some of which appear on a second web page; 
software portions configured to save the user's choices; and software portions configured to 
create a combination web page that is based on the first web page and the second web page, 
and includes the elements chosen by the user in accordance with the user's saved choices. 

25 In further accordance with the purpose of the invention, as embodied and broadly 

described herein, the invention relates to an apparatus that creates a combination web page, 
comprising: software portions configured to store in a memory selection information 
specifying the elements on a combination web page, the combination web page being based 
on at least two original web pages; software portions configured to retrieve the original web 

30 pages upon which the combination web page is based; and software portions configured to 
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create the combination web page from elements on the original web pages in accordance with 
the selection information. 

In further accordance with the purpose of the invention, as embodied and broadly 
described herein, the invention relates to a server apparatus, comprising: software portions 
5 configured to receive, from a client, a request for multiple web pages; software portions 
configured to retrieve the multiple web pages; software portions configured to send the 
requested multiple web pages to the client; software portions configured to receive, from the 
client, selection information for the requested multiple web pages, the selection information 
indicating a subset of the information of the web pages that is smaller than the set of all 

10 information on the web pages; and software portions configured to store the selection 
information in the server data processing system. 

In further accordance with the purpose of the invention, as embodied and broadly 
described herein, the invention relates to a server apparatus, comprising: software portions 
configured to receive, from a client, a request for a user's combination web page; software 

15 portions configured to retrieve at least two web pages upon which the user's combination web 
page is based; software portions configured to select portions of the retrieved web pages in 
accordance with selection information of the user stored in the server data processing system; 
and software portions configured to send the user's combination page, containing the selected 
portions of the retrieved web page to the user. 

20 Advantages of the invention will be set forth in part in the description which follows 

and in part will be obvious from the description or may be learned by practice of the 
invention. The objects and advantages of the invention will be realized and attained by 
means of the elements and combinations particularly pointed out in the appended claims and 
equivalents. 

25 

BRIEF DESCRIPTION OF THE DRAWINGS 

The accompanying drawings, which are incorporated in and constitute a part of this 
specification, illustrate several embodiments of the invention and, together with the 
description, serve to explain the principles of the invention. 
50 Fi g- 1 is a block diagram of data processing elements in accordance with a preferred 

embodiment of the present invention. 
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Figs. 2(a) and 2(b) are block diagrams showing an information flow in a preferred 
embodiment of the present invention. 

Fig. 3(a) shows a display of a startpage that allows a user to create and edit shortpages 
and combopages. 
5 Figs. 3(b)-3(e) show the HTML source for a startpage. 

Figs. 4(a)-4(c) are flow charts showing how a client and a server interact to perform 
shortpage operations, such as create, edit, delete, and view. 

Fig. 5(a) shows a display of an exemplary web page. 

Figs. 5(b) and 5(c) show the web page of Fig. 5(a) displayed along with selection- 
1 0 enabling information. 

Fig. 5(d) shows the web page of Fig. 5(b) with a different level of block detail. 

Fig. 5(e) shows a web page that allows the user to view/edit shortpage properties. 

Fig. 6 is a flow chart showing how the client and the server interact to allow the user 
to create/edit a shortpage. 
1 5 Fig. 7 shows an example of HTML parsing used to create/edit shortpages. 

Fig. 8 shows an example of a split page method used to create/edit shortpages. 

Fig. 9 is a flow chart of how to determine a display level when creating shortpages. 

Fig. 10 shows the startpage of Fig. 3(a) after a shortpage has been created based on 
the web page of Fig. 5(a). 
20 Fig. 1 1 shows the shortpage created from the web page of Fig. 5(a). 

Fig. 12 shows a fullpage corresponding to the web page of Fig. 5(a). 

Fig. 13 is a flow chart showing how the client and server interact to allow the user to 
view a shortpage. 

Fig. 14 is a flow chart showing details of determining whether a URL is the URL of a 
25 shortpage. 

Fig. 1 5(a) shows a display for creating a combopage. 

Fig. 1 5(b) shows an example of a combopage. 

Fig. 16(a) is a flow chart for creating a combopage. 

Fig. 16(b) is a flow chart for displaying a combopage. 
30 Fig. 1 6(c) shows a web page that allows the user to view/edit combopage properties. 

Fig. 17(a) shows a display for viewing a parameterized combopage. 
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Fig. 17(b) shows an example of a parameterized combopage. 
Fig. 17(c) shows another example of a parameterized combopage. 
Fig. 18(a) is a flow chart for creating a parameterized combopage. 
Fig. 1 8(b) is a flow chart for displaying a parameterized combopage. 
Fig. 19 is a flow chart for viewing a shortpage when the client is a personal digital 
assistant. 

Fig. 20 is a block diagram of data flow when a shortpage or a combopage is viewed 
on a personal digital assistant. 

Fig. 21 is a display of a shared portal shortpage. 

DETAILED DESCRIPTION OF EMBODIMENTS 

Reference will now be made in detail to several embodiments of the present invention, 
examples of which are illustrated in the accompanying drawings. Wherever practicable, the 
same reference numbers will be used throughout the drawings to refer to the same or like 
parts. 

I. General Discussion 

A described embodiment of the present invention allows users to select certain sub- 
elements of one or more web pages as a shortpage. The user selects certain sub-elements of 
an original web page to create a shortpage. The user's selection information is saved and, 
when the user views the shortpage at a later time, only the sub-elements of the web page 
indicated by the user are displayed for viewing by the user. Thus, the user views only 
preselected sub-elements of the web page. "Combopages" (short for "combination pages' 1 ) 
are created by combining shortpages or from combining selections from more than one web 
page or site. This section discusses an exemplary data processing system used to implement a 
preferred embodiment of the present invention. 

Fig. 1 is a block diagram of data processing elements in accordance with a preferred 
embodiment of the present invention. Fig. 1 includes a server data processing system 120 
communicating with one or more client data processing systems. These client data 
processing systems include, but are not limited to, a desktop personal computer (PC) 102, a 
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laptop computer 104, a palm computer (personal computer/assistant or handheld device) 106, 
a pager 108 (such as an alphanumeric pager), a web-enabled telephone or a cell phone 1 10, or 
some other appropriate web-enabled device or appliance 1 1 1. A web-enabled telephone or 
device could use, for example, the WAP (Wireless Application Protocol) or any other 
appropriate protocol. It should be understood that the client data processing systems shown 
in Fig. 1 are shown for purposes of example only and are not to be construed in a limiting 
sense. Any other appropriate type of client can be used in conjunction with the present 
invention. Fig. 1 also includes a plurality of web page servers 132, 134, 136. Each web page 
server communicates with server 120 and stores one or more web sites or web pages. Server 
120 stores selection information 122 for each user and further stores selection-enabling 
information 124 that is added to a web page to enable a user to make selections from a web 
page. Communication can be over a network, such as the internet, an intranet, a wireless 
network, or in any other appropriate manner. 

Fig. 2(a) shows an overview of creation of a shortpage. As shown in Fig. 2(a), during 
operation, a client 202 sends a request to server 120 for a web page. Server 120 retrieves the 
web page from an appropriate one of web sites 132-136. The server 120 adds selection- 
enabling information to the retrieved web page and sends the web page to the client. The 
client selects sub-elements of the web page and sends that selection information to server 
120. Server 120 stores selection information 122 describing the shortpages defined by a user. 

Fig. 2(b) shows an overview of viewing a shortpage. The client sends a request for a 
shortpage (or a combopage) to server 120. Server 120 determines the page or pages needed 
to view the shortpage or combopage in accordance with the stored selection information and 
retrieves the page or pages from the web site 132. Server 120 shortens the retrieved web page 
in accordance with the selection information to form a shortpage and sends the shortpage to 
the client. 

It should be understood that each of the clients, servers, and web servers in the 
described embodiment includes a processor and a memory. The memory includes 
instructions capable of being executed by the processor to perform the functions described 
below. A client and/or a server can also include a computer readable medium for storing the 
instructions. Server 120 communicates with the clients and the web page servers via any 
appropriate communication mechanism, including but not limited to a network, an intranet, 
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the internet, wireless communications, telecommunications, cable modems, and satellite 
communications. 

A client may include browser software suitable for viewing web pages. The browser 
software can be standalone or integrated within other software products. The functionality 
can be stored, for example, as a link, a JavaScript, or as a Java applet. Handheld clients 
contain a specialized browser that receive "snipped" sub-elements of web pages for viewing 
on a handheld client. Other clients (such as cell phones) do not necessarily contain a browser. 
It should be understood that references herein to "HTML" can be understood to refer to any 
appropriate page specification language, such as a hypertext language or a proprietary 
language. 

The following paragraphs describe an example of how a user makes a shortpage. This 
example is provided for exemplary purposes only and is not to be interpreted in a limiting 
sense. 

Fig. 3(a) shows a display of a "startpage" on a browser in a client. The startpage 
allows a user to create and edit shortpages and combopages and displays existing shortpages 
and combopages. Each user has his own startpage. The information needed to make a 
startpage is preferably stored in server 120. Fig. 3(a) shows a URL 310 of the exemplary 
startpage for user John Smith 

(http://ww.shortware.com:9999/UserName=Jsmith&ProcName==StartPage). 

The startpage of Fig. 3(a) includes a link to a Notifications page 312, a link to an Edit 
profile page 314, and a link to a Help page 316. The startpage of Fig. 3(a) allows a user to 
create, edit, delete, and view shortpages and their options. To create a shortpage, in the 
described embodiment, the user enters a URL of a page into area 318 and selects "Create 
Shortpage" button 320. After a shortpage is created, its name will be displayed in Shortpages 
column 332. An existing shortpage can be viewed ("Go"), edited, options edited, or deleted 
by selecting the corresponding action in action box 330 and selecting a name of an existing 
shortpage. Creation, editing and deleting of combo pages are discussed in detail below. 

Figs. 3(b)-3(e) are an example of the HTML source code for an exemplary startpage, 
similar to the StartPage of Fig. 3(a). This source code is included for the purpose of example 
and is not to be taken in a limiting sense. 



8 



WO 01/11502 



PCT/USOO/21701 



Figs. 4(a)-4(c) are flow charts showing how a client and a server interact to perform 
shortpage operations, such as create, edit, delete, and view. Figs. 4(a) and 4(b) show a 
method performed by the client. In the described embodiment, the functionality of Figs. 4(a) 
and 4(b) are implemented via a Java Script executed by the client browser, although any 
5 appropriate implementation can be used. Fig. 4(c) shows a method performed by server 120. 

In Figs.4(a) and 4(b), the client receives the user's actions (e.g., entering the URL of a 
web page and clicking "Create shortpage") and determines whether the user wants to create a 
shortpage (element 410), edit a shortpage (element 420), view a shortpage (element 430), 
delete a shortpage (element 440), or edit an option (element 450). 

10 If the user wants to create a new shortpage (element 410), the client sends the URL of 

the page to shorten and a request to create a shortpage to server 120. The client receives a 
page created from the requested page and from selection-enabling information. In the 
example, the selection-enabling information allows the user to indicate that sub-elements of 
the page are shown or hidden. The client then displays the page, and allows the user to create 

15 a shortpage as described below. The resulting selection information is sent to server 120. In 
the described embodiment, selection information is sent to the server each time a page 
element is marked as "shown" or "hidden." In return, a new preview of the shortpage is sent 
from the server to the client, so that the preview view of the short page reflects the currently 
shown/hidden element. The server adds the name of the shortpage to the list of shortpages 

20 332 on the page. 

If the user wants to edit a shortpage (element 420), the client sends the URL of the 
shortpage to edit and a request to edit a shortpage to server 120. The client receives a 
shortpage created from the original fullpage including selection-enabling information. The 
selection enabling information includes show/hide buttons and header links. The client then 

25 displays the page upon which the shortpage is based, including the selection-enabling 
information, and allows the user to edit the shortpage as described below. The resulting 
selection information is sent to server 120. Note that the show/hide buttons can instead be 
implemented as a one-button user interface, or by using some other appropriate type of user 
interface that allows the user to choose a subset of the web page elements. 

30 If the user wants to view a shortpage (element 430), the client sends the URL of the 

shortpage to view and a request to view a shortpage to server 120. The client receives the 
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shortpage from server 120. The shortpage to be viewed does not include any selection- 
enabling information. The client then displays the shortpage. 

If the user wants to delete a shortpage (element 440), the client sends the URL of the 
shortpage to delete and a request to delete a shortpage to server 120. Server 120 deletes the 
5 shortpage and returns an indication to the client that the shortpage has been deleted. The 
server removes the name of the shortpage from its list of shortpages 332. 

If the client wants to edit options for a shortpage, the client sends the URL of the 
shortpage and a request to edit the options of the shortpage. The client receives the edit page 
from server and displays it. The user then edits the options and sends the edits to the server. 

10 Fig. 4(c) shows an overview of an exemplary shortpage method on the server side. 

When the server receives a request from the client's browser to create, edit, delete, or view a 
shortpage or option (element 450), the server translates the request into the appropriate 
request(s) to the web server(s) and retrieves the requested web page(s) or site(s) from the 
server(s) (element 452). In the described embodiment, these requests are HTTP requests and 

1 5 the web pages are written in HTML or a similar hypertext language. The server does the 
user-specified action (such as adding selection-enabling information when a shortpage is to 
be created or edited) or selecting the relevant parts of the web page (when a shortpage is to be 
viewed) (element 456). For example, the server adds the selection-enabling information to 
the retrieved web page and sends the resulting page to the client's browser. Table 1 shows an 

20 example of Web Procedure Calls (WPCs) used to communicate between the client and the 
server. The WPC is part of the URL sent by the client and has the format: 

/UserName=<username>&ProcName=<procname>{&argl=vall } {&arg2=val2} . . . {& 
argiast=vallast} 

where a string in pointed brackets "<" ">" indicates a type of data and a string in curly 
25 brackets " {" "} " indicates optional arguments. 

II. Creating/Editing a Shortpage 

The following paragraphs provide exemplary details of how to create/edit a shortpage. 
The example shown in based on an exemplary web page shown in Fig. 5(a). The web page 
30 shown has a URL of http://abc.gov. In the example, a user visits this web site frequently and 
desires to select sub-elements of the web site to be placed on a shortpage. If the user desires 

10 
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to create a shortpage based on the web page of Fig. 5(a), he enters the URL of the web page 
into address 318 of Fig. 3 and selects "Create Shortpage" button 320. The server will retrieve 
the requested web page and add selection-enabling information to the page. 

Figs. 5(b) and 5(c) show the web page of Fig. 5(a) displayed along with selection- 
5 enabling information. The server has broken the web page into blocks, each block having 
selection-enabling information. In the described embodiment, the selection-enabling 
information is a pair of show/hide boxes, having a check mark and an "X" respectively. The 
check mark indicates that the corresponding block will be shown in the shortpage. The "X" 
indicates that the corresponding block will be hidden (not shown) in the shortpage. Fig. 5(b) 

10 shows an editing area 510 and a preview area 520. Each of these areas can be sized and 
scrolled by the user. Initially all blocks in the page are marked as "hide.*' The example of 
Fig. 5(b) shows all blocks marked as "show." Therefore, in the example, preview area 520 
shows all blocks in the page. In contrast, in Fig. 5(c), the user has clicked on the "X" box 
505, causing the corresponding block 504 to be hidden in the shortpage. Note that the block 

1 5 504 is not shown in the preview area 520 of Fig. 5(c). 

Fig. 5(d) shows the web page of Fig. 5(a) with a different level of block detail. When 
the user clicks "more details" link 561 of Fig. 5(c), a command is sent to the server and the 
server re-determines the blocks of the page using a higher level of detail than previously used. 
(A similar "less detail" button 561 ' is displayed on the web page of Fig. 5(d)). A method of 

20 determining blocks on a page in accordance with a current level of detail is described below 
in connection with Fig. 9. In Fig. 5(d), for example, the page is broken into fewer blocks. 
For example, block 504 does not exist in editing area 510. 

Fig. 5(e) shows a web page that allows the user to view/edit shortpage properties. The 
web page of Fig. 5(e) is requested when the user clicks on "Next" link 560, as shown in Figs. 

25 5(b) - 5(d). This page allow the user to enter properties of a shortpage. The user can change 
the name associated with the shortpage (for example, the name shown in area 332 of Fig. 3) 
by entering a new name in area 570. The user can enter comments in area 572. The user can 
indicate that the shortpage does not show the page background in area 574. The user can 
indicate that changes since the last time the shortpage was viewed should be highlighted on 

30 the shortpage in area 576. The user can indicate that the shortpage should be used for similar 
pages and all URLs starting with a specified string (areas 578 and 580). Other properties 
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could be included or certain properties shown in the figure excluded without departing from 
the spirit or scope of the invention. When the user clicks a "Done" button 582, the client 
sends the entered information to server 120, which stores the entered information in 
connection with the shortpage. 

5 Fig. 6 is a flow chart showing how the client and the server interact to allow the user 

to create/edit a shortpage. Each element of the flow chart has a notation next to it indicating 
whether it is preferably performed by the client, server, or a combination. In element 602, 
after the server has retrieved a page from a web server, the server needs to break the page 
down into blocks and to add selection-enabling information to the page for each block. The 

10 server uses the SplitPage method (Fig. 8) and the Level of Detail method (Fig. 9) to break the 
page into blocks. In element 604, the server adds selection-enabling information to the 
retrieved web page. Specifically, the server adds a "Show" button and a "Hide" button next 
to the block and puts a border (<table>) around it. The client's browser, thus, displays the 
web page along with the selection-enabling information for each block. 

15 When the user selects "Show" or "Hide," an HTTP request that uniquely identifies the 

button is sent to the server (see Table 1). In element 608, the server marks the corresponding 
block as either "shown" or "hidden" in the representation tree (RepTree) for the shortpage. 
This information is a part of the selection information stored on the server. In element 610, 
the server returns a preview of the resulting shortpage to the user, which is displayed in a 

20 separate frame (preview area 520). The marked-up RepTree is stored as the template for 
future references to this shortpage. Thus, the RepTree forms at least part of the selection 
information. It will be understood that, although the example shows certain actions being 
performed by the client or the server, other embodiments may implement the client or server 
to perform actions not shown as being performed by them. For example, the selection 

25 information could be stored on the client side. 

Fig. 7 shows an example of parsing used by the server to create and edit shortpages. 
This figure shows the Split Page method. In the example, a page is represented by an HTML 
file. The HTML is parsed in a manner known to persons of ordinary skill in the art to yield a 
Representation Tree. The Representation Tree has complex/multipart tags (e.g., <ul>), 

30 simple tags (e.g., <img src=Img.gi£>), and text nodes (e.g., iteml). A simple tag is defined as 
a tag that has no children and a complex tag is defined as a tag that has children. Server 120 
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parses the HTML file into a RepTree and iterates down the tree in a depth-first way to mark 
each node in the tree according to whether it is a single block. The RepTree includes a flag 
for each block indicating whether it is shown or hidden. A detailed example of the format of 
a RepTree is shown in Table 2. This format is not to be taken in a limiting sense. 
5 Fig. 8 shows an example of a split page method used to create/edit shortpages. As 

shown in Fig. 8, if a node corresponds to a simple tag that is an image, input, iframe, or 
object, it is marked as a single block. If a node corresponds to a complex tag of type <tr> and 
there are more than two rows or columns in the table, mark the node. If a node corresponds 
to a complex tag of type <form>, do not mark the node. If a node corresponds to a complex 

1 0 tag of other types, mark the node if it has any text. For other types of nodes, continue 
traversing the RepTree. For each complex node, walk down the list of its children. Any 
nodes between two single blocks become one complex block. To avoid creating extra blocks, 
if a node has only one child block, give the block status to the parent node instead. 

Fig. 9 is a flow chart of how to determine a display level when creating shortpages. In 

15 the described embodiment, the level of detail is used to decrease the number of blocks 

displayed at a given time. This flow chart demonstrates how to work with two levels (high 
and low), but any number of levels can be supported. If the level of detail is low, element 
904 determines whether the block's parent has less than L nodes below its children. L can be, 
for example, 5. If the block's parent has less than L nodes below its children, the block is 

20 shown as a separate block when the user creates or edits a shortpage. Otherwise, the block is 
not shown as a separate block. If the level of detail is high, element 906 determines whether 
the block has more than K nodes below its children. K can be, for example, 1 . If the block 
has more than K nodes below its children, the block is shown as a separate block when the 
user creates a shortpage. Otherwise, the block is not shown as a separate block. 

25 Fig. 10 shows the startpage of Fig. 3 after a shortpage has been created based on the 

web page of Fig. 5(a). Server 120 indicates to the client that a shortpage has been created 
and adds the name of the shortpage to area 332 of the user's startpage. The startpage having 
the name of the new shortpage is sent to the browser, where it is displayed. 

Fig. 1 1 shows the shortpage created from the web page of Fig. 5(a). In the example, 

30 the user selected certain sub-elements of the page. Specifically, the user indicated that all but 
a leftmost block of the page is marked as hidden. Thus, the shortpage shows only the non- 
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hidden block. The shortpage also includes a link to the user's startpage 1 102, a link to a 
notification page 1 104, a link to a help page 1 106, a link to a page that allows the user to edit 
a shortpage 1 105 and a link to the fullpage 1 103 upon which the shortpage is based. Note 
that the user has indicated that the background of the original page is not to be shown in this 
shortpage (see Fig. 5(e)). 

Fig. 12 shows a fullpage corresponding to the web page of Fig. 1 1 . The fullpage is 
displayed when the user clicks on the fullpage link 1 103 of Fig. 1 1. In contrast to the 
shortpage, the original page's background is shown, since it is part of the page. Even though 
all blocks of the fullpage are shown, the full page is fetched via server 120 and not directly 
from the web page server. This is shown by the URL of the fullpage: 
http://shortwave.com:9999^ 
txtURL=http://www.abc.gov . 

In this example, the user is "JSmith". The action is to get/fetch a page. "Purpose = 7" 
indicates that a full page should be fetched. The URL of the full page is http://www.abc.gov. 
Further example of parameters used to communicate between the client and the server are 
described in Table 1 . 

III. Viewing a ShortPage 

Fig. 13 is a flow chart showing how the client and server interact to allow the user to 
view a shortpage. In the described embodiment, the user has selected a name of a shortpage 
in area 332 and selected "go" in area 330. It should be remembered that, although a 
shortpage may be based on a particular web page, that web page may have changed since the 
shortpage was created, either because content may have been changed, added, or deleted. It is 
necessary to parse the web page on which the shortpage is based (the target) and determine 
whether the blocks marked "show" in the template are still present in the target. The target 
page on which the shortpage is based is retrieved and parsed into a RepTree by the server. 
Each shortpage has a RepTree associated with it. 

In element 1304, the server performs a "double traverse" method, recursively 
traversing down both the template and the target RepTrees, trying to match the nodes. If two 
nodes match by type and tag, assign the "Show" or "Hide" flags of the template node to the 
target node. If there is no match, start to look for the closest match. If, for example, we are 
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currently on nodes Temp[I], Targ[J], then we are looking for matching Temp[K] and Targ[L] 
such that, for K and L, K-I+L-J is the smallest possible value. 

After element 1308, any template nodes that are not matched were the nodes that have 
disappeared from the page. Any target nodes that were not matched were the nodes that have 
been added to the page. All target nodes with "Show" flags (i.e., all target blocks that 
matched a block in the template) are part of the shortpage. These blocks are sent to the 
requesting client. Other appropriate matching methods can also be used. 

In the described embodiment, the user can enter the address of a web page to be 
shortened. For example, the user can enter a URL in area 318 and click on button 340. If the 
user has previously defined a shortpage for this URL or for a URL on this web site, the 
shortpage is displayed. Similarly, if a page has a link to another page within it and the link is 
selected, server 120 will check the new link to determine whether it is a shortpage. 

Fig. 14 is a flow chart showing details of determining whether a URL is the URL of a 
shortpage. As described in element 1402, this method will be used when, instead of 
requesting a specific shortpage, the user enters or browses to a particular URL. In element 
1404, for each shortpage that the user has, server 120 compares the URL, host name, 
document name, and CGI argument lists. The server does this for both a shortpage requested 
address and for the actual address. The requested address and the actual address may be 
different because of HTTP redirection. 

If, in element 1406, the host name, document, name, and CGI parameter names 
match, it is a "clear match." If a clear match occurs, use this shortpage for customizing the 
request. If a clear match does not occur, control passes to element 1410. In element 1410, 
for each "approximate match" (which is defined as host name and document name match), 
calculate "match ranking." Step 1412 calculates match ranking as follows. For each 
matching RepNode of RepTree, add (l/(Node depth)) to the rank. For each mismatch, 
subtract the same amount. In step 1414, select the shortpage with the highest matching rank 
for customizing this request. If no match occurs, then show the full page. 

IV. Creating/Editing/Viewing a Combopage 

A described embodiment of the present invention allows the user to define a 
"combination page" (also called a "combopage"). A combopage is a page made up of more 
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than one web page. In the described embodiment, a combopage is made up of a combination 
of shortpages. Other combopages are made up of information from more than one web page, 
but not necessarily from other shortpages. 
i. Standard Combopages 

Fig. 15(a) shows a display for creating a combopage. In the example provided, 
combopages are created by combining shortpages. Combopages can also be created in a 
manner similar to that of shortpages without explicitly creating shortpages first. The display 
of Fig. 15(a) is displayed by a browser of a client. An area 1502 contains the names of all 
shortpages created by the user. Selected shortpage area 1504 contains the names of all 
shortpages selected by the user to be in the combopage. In the example, no shortpages have 
been selected yet. 

Arrow buttons 1506 cause a shortpage name to be added to or removed from area 
1504 Each time the user clicks on one of buttons 1506, a message is sent to server 120, 
which returns a redrawn page and stores the change to the combopage. Up and Down buttons 
1508 allow the user to change the position of a shortpage within a combopage. Each time the 
user clicks on one of buttons 1508, a message is sent to server 120, which returns a redrawn 
page and stores the change in position of the elements in the combopage. 

Fig. 15(b) shows an example of a combopage. In the example, the combopage . 

r ♦ ,u n ^o P 1 552 and a second shortpage 1 554. The 
made up oftwo shot, pages: a firs, shortpage l**- ^ 

combopage also inCudes a Us* » » user's «P» * * * -| 

(see Fig. 16(c)). It should be noted that the shortages used to make Ore com p 

ftom the same site or from different sites ^ 
Fig. 16(a)isaflow char, for cccatmgacomhopageu.ug P 

5 to shortpages ou to comhopagc. Element 1604 stores 

shortpages and their positions. , hv server 120 to display a previously 

Fig . 1<W is a flow char, of a metod performed hy -™i ^ ^ 

towage to, is par, of to combopage, to server -* ^ ^ ^ ^ ^ 

30 sneserve, In element f6 5 6, to server waits uu.tlal, torques, 
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site servers or a time-out expires. In element 1658, the server creates an HTML table for the 
combopage and, in element 1650, sends the resulting HTML to the client. 

Fig. 16(c) shows a web page that allows the user to view/edit combopage properties. 
The web page of Fig. 16(c) is preferably requested when the user clicks on "Next" link 1508, 
5 as shown in Fig. 15(a). The user can change the name associated with the combopage by 
entering a new name in area 590. The user can indicate that the contents of the combopage 
are to be enclosed in an HTML table in area 592. When the user clicks a "Done" button 582, 
the client sends the entered information to server 120, which stores the entered information in 
connection with the combopage and returns the user to the user's startpage. 

10 

ii. Parameterized Combopages 

The following paragraphs discuss a specialized type of combopage called a 
"parameterized combopage." A parameterized combopage is similar to a regular combopage, 
but it saves the user from having to type in the same parameter more than once. A 

1 5 parameterized combopage is created as shown in the flow chart of Fig. 1 8(a). 

As shown in element 1802 of Fig. 18(a), after the user has selected shortpages having 
CGI parameters and entered CGI parameters on at least two shortpages, the server compares 
the CGI parameters for the URLs. If there is a CGI parameter which appears in all CGI 
requests, the server determines that the combopage is a parameterized combopage. In 

20 element 1 808 1 , the server marks the common CGI parameter as a special combopage 

parameter and stores an indication that this combopage is a parameterized combopage. Thus, 
in the described embodiment, the server, not the user, determines that the combopage is 
parameterized. Although the invention is described in connection with CGI parameters, other 
types of parameters can be used. 

25 Fig. 1 7(a) shows a display for viewing a previously created parameterized 

combopage. When a user indicates that he wants to view a combopage that has been 
determined to be parameterized (see Fig. 3(a)), the server sends a prompt 1702 for the user to 
enter a parameter value. In the example, the user has entered a parameter value of "ABC" 
Fig. 18(b) is a flow chart for displaying a parameterized combopage. As shown in 

30 element 1 852, the server receives the request for the combopage from the user and determines 
that the requested page is a parameterized combopage, based on the stored indication from 
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element 1808. The server asks the user to enter the parameter value (see Fig. 17(a)). In each 
URL of the shortpages making up the combopage, the server replaces the original value of the 
parameter by the one entered by the user. The server then sends the HTML for the 
parameterized combopage to the client for display. 

5 Fig. 17(b) shows an example of a parameterized combopage. In the example, the 

combopage is made up of three shortpages 1752, 1754, and 1756, each having an associated 
CGI parameter. Here, the user has entered a value of "ABC in the prompt of Fig. 17(a). The 
server fills in the CGI parameters for each of the three pages upon which the shortpages are 
based and retrieves the pages from their respective web site servers. The server then takes the 

10 sub-elements of the three pages that form the shortpages and combines them to form the 
combopage. Thus, the user enters the parameter value "ABC" only one time, but the 
parameterized combopage contains information from three different sources relating to 
"ABC". 

Fig. 17(c) shows another example of a parameterized combopage. In this example, no 
1 5 separate page is required for entry of a parameter. Instead, an area 1 772 allows the user to 
enter a parameter value 1771 (here the user has entered "abc, Inc."). The shortpages (or sub- 
elements of web pages) making up the parameterized combo page are retrieved as described 
above and the parameterized combo page is completed and sent to the client where it is 
displayed as shown in Fig. 17(c). In this example, the user has entered the parameter "abc, 
20 Inc.". This parameter is sent as a parameter to the pages used to make the combopage and the 
resulting shortpages, which preferably have information about the parameter abc, Inc. are 
created and used to make the parameterized combopage. Thus, in the example, shortpage 
1774 contains information about the parent company of abc, Inc. while shortpage 1776 
contains information about the stock price of abc, Inc. If the user enters a different parameter, 
25 the types of information on the combopage remain constant, but the company described 
changes in accordance with the parameter. 

V. Handheld client 

As discussed in connection with Fig. 1, the present invention can be implemented for 
30 a wide variety of clients. Fig. 20 is a block diagram of data flow when a shortpage or a 
combopage is viewed on a personal digital assistant, such as a Palm VII Personal Digital 
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Assistant (Available from 3Com Corporation) or a similar handheld device. PDAs often use 
a "web clipping" system to view web pages. The PDA views predefined web clippings by 
sending a request for the clipped pages to a proxy server. 

Initially, a "web clipping" application, which contains a single link to the user's 
5 startpage is created and downloaded into the user's handheld device. The user creates his 
shortpages and combopages as described above. Preferably, these shortpages and 
combopages are created on the user's PC, although other embodiments may allow the user to 
create them on the handheld. 

To view a shortpage or a combopage, the user simply goes to his startpage "web 

10 clipping" in the handheld and selects a link to the shortpage. As shown in Fig. 20, this action 
causes a request to be sent to the proxy server 2004, which passes the request to the shortpage 
server 2006, which forwards the request to the web site 2008 hosting the full page (or full 
pages in the case of a combopage). The web site returns the requested page(s) to the 
shortpage server 2006, which creates a shortpage or a combopage as described above and 

1 5 which then passes the created shortpage or combopage to the proxy server 2004. The proxy 
server sends the shortpage or combo page to the handheld client 2002. 

Fig. 19 is a flow chart for viewing a shortpage when the client is a personal digital 
assistant. In element 1902, a web clipping short page application, which contains a single 
link to the user's startpage is created and downloaded into the user's PDA. In element 1904, 

20 the user creates his shortpage (or combopage) as before, using his PC or similar device. In 
element 1906, to view a shortpage or combopage, the user simply goes to his startpage "web 
clipping" and selects a link to the shortpage. In element 1908, the request goes through a 
proxy server (such as palm.net of 3Com) and is forwarded to the site hosting the page or 
pages. In element 1910, the response from the web server is customized by the Shortpage 

25 server and goes back to the user. 

In the described embodiment, the shortpage server creates a modified version of a 
shortpage when it knows that the client is a handheld device. For example, the shortpage 
server removes large graphic files and Java Script code. Other embodiments may make other 
modifications or no modifications, depending on the nature and capabilities of the handheld 

30 client. In the described embodiment, the proxy server also modifies the page somewhat 
before sending the page to the handheld client. 
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VI. Shared Portal 

Fig. 21 is a display of a shared portal shortpage application. A shared portal is created 
by one or more persons and is viewable by multiple persons. Different users may have 
5 different access permissions stored within the server. For example, in one embodiment, a 
single user has permissions to create folders (such as folder 2102), but any user can add 
shortpages within folders (link 2104 is a link to a combopage titled "Bay Area News"). As 
another example, only a single user can add folders and links, but any user can access the 
shortpages and combopages. In a shared portal, whenever a user attempts to edit or create a 

10 shortpage or combopage, the server first checks the permissions of the user. The user may be 
required to enter a password and/or to Log on from an approved machine. Similarly, 
whenever a user attempts to access a shortpage or a combopage, the server checks the 
permissions of the user to determine whether the user is authorized to access the page he has 
requested. A shared portals may be open to all users or may be restricted to certain groups, 

1 5 such as families, employees of a company, employees of a department, or clubs. 

VII. Cluster Implementation 

In one embodiment of the present invention, server 120 resides on a number of nodes, 
which are dual-Pentium Windows NT PCs. In this implementation, data is stored in a shared 

20 RAID file server. A hardware load-balancer, such as a Big/IP load balancer from FS 

Networks, Inc. of Seattle, Washington is used to route user requests to the least busy node. 
Such an implementation uses persistent connections with, for example, a ten minute timeout 
to ensure that the requests from the same address get to the same server. When the first 
request for the given user comes to the given server, the user's data is read from the file 

25 server. If there is no activity for the time Q (for example, Q>T, 12 minutes), the data for the 
user is cleared from memory. 

While the invention has been described in conjunction with a specific embodiment, it 
is evident that many alternatives, modifications and variations will be apparent to those 
skilled in the art in light of the foregoing description. For example, in one embodiment, 

30 shortpages and/or combopages are pre-created and offered to third persons who want 

specialized information or who want shorter web pages. In another embodiment, shortpages 

20 



WO 01/11502 



PCT/US00/21701 



can be located on a combopage next to each other in a horizontal direction. Accordingly, it is 
intended to embrace all such alternatives, modifications and variations as fall within the spirit 
and scope of the appended claims and equivalents. 
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Table 1 (Page 1 of 1) 

WPCs - Web Procedure Call list 
All WPCs take a username. 

5 

// The WPC consists of: (without "<" or ">") 
// 

/Usemame=<usemame>&ProcName==<procname>&arg 1 =val 1 &arg2=val2& . . . &argLast=val 
Last 

10 // (The number of args is variable, and the "last" arg is optional). 
// New user registration and user login. 

NewUserLogin - Allows the user to enter registration information 
1 5 RegisterUser - Submits username, full name, password, email, and other info for a new user. 
LoginUser - login user. Takes username and password 

// Wizard Action 

WizardAction - takes object (shortpage, notification, or combopage) id 
20 Edit - start editing the object 

Props - Displays properties of the object 

CreateShortpage - creates a shortpage 

CreateNotification - creates a notification 

CreateCombopage - creates a combopage 
25 Browse - browse to the given URL 

Go - go to the given shortpage/combopage 

Delete - delete given object 

Next - present logically the next screen in the wizard 

Done - done with the editing 
30 Cancel - cancel editing 

B_GetPage - Get a page. Takes a URL 

B_GetPageS - Same, but the request came through a script, URL needs some massaging. 
Takes a URL and a base URL for the page to be appended to it. 
35 StartPage - show Start Page for the user 

NotifPage - Show notification page for the user 

UJDeleteNotifs - delete certain notification messages. Takes message ids. 
P_SelectionFrame - Displays the selection frame (upper frame) for the shortpage creation 
PJDoCommand - do editing command, such as "Show" block, or "Hide" block. 
40 Takes block id as a parameter, and command id ("Show", "Hide", "Notify", etc.) 

ProfileMgrAction - Edit profile settings 
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Table 2 (Page 1 of 2) 

typedef CArray<CRepNode*, CRepNode*> CRepNodeAiray; 

5 class CRepNode 
{ 

friend class CRepBuilder; 

public: 

CRepNode(CRepNode *pParent=NULL, int ilndex=0); 
10 virtual -CRepNodeO; 

void AddChild(CRepNode *pChild); 

void InsertChild(CRepNode *pChild, int ilndex); 

15 void Serialize(CMyArchive& ar); 

enum Type{ 
NONE, 
TEXT, 

20 SIMPLE_TAG, 

CONTAINER_TAG, 
COMMENT, 

BADTAG, // bad closing tag. 

SCRIPT, // script node contains both <SCRIPT> and </SCRIPT> 
25 WHITESPACE,// whatever "trims" to an empty string. 

BAD_C LOSING 

}; 



30 



35 



40 



Type m_Type; 

#define FLG_BLOCK_BEGIN 0x1 
#define FLG_BLOCK_END 0x2 

#define FLG_BLOCK_MASK (FLG_BLOCK_BEGIN | FLG_BLOCK_END) 

#define FLG_HIDE 0x1 0 // hide this node. 
#define FLG_CHANGED 0x20 // node has changed 

#define FLG_NOMATCH 0x40 // couldn't match this node. 

#defineFLG SHOW 0x80 // show the node and subnodes. 



#define FLG_NOTIFY 0x1 00 // Notify on this node. 

#define FLG_BADLY_CLOSED 0x200 // This node is incorrectly nested. 
#defme FLG_TEMP OxfOOO // The mask for temp bits used by stuff 

// here and there for a short time. 

45 Table 2 (Page 2 of 2) 

ULONG m_Flags; 
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CNodelnfo *m_pInfo; // any data can be stored here. 

// not saved to the disk! 

5 CNotifylnfo *m_pNotify; // Notification info on this node. 

// must be serialized. 

// has either the text, or a simple tag or 
// the full tag with params, but without nested tags.. Example: 
1 0 // "<TD WIDTH=1 17 VALIGN=TOP ALIGN=LEFT>" 

CString m_Text; 

// Children of a complex tag. 
CRepNodeArray m_aKids; 

15 

// the following two fields are redundant for all known (to our 
// program) tags. 

20 TAG m_Tag; 

// The tag without params and < or >, like "TD" 

// Note that there is never a closing tag, like </TD> in the representation. 
// If the type of the node is CONTAINER_TAG, then it is assumed that 
// there is a closing tag after all m_aKids. 
25 CString mJTagName; 

CString m_NodeHeader; 

CRepNode *GetParent() { return m_pParent; } 
30 int Getlndex() { return m_Index; } 

CRepNode *m_pParent; // root object has this NULL 
int m_Index; // index into the array of the parent node. 

35 #if DEBUG 

void AssertValid(); // CObject-like validation function. 

#endif 

}; 
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WHAT IS CLAIMED IS: 

1 . A method for creating a combination web page, comprising: 

allowing a user to choose a subset of elements, some of which appear on a first 
web page and some of which appear on a second web page; 
saving the user's choices; and 

creating a combination web page that is based on the first web page and the 
second web page, and includes the elements chosen by the user in accordance with the user's 
saved choices. 

2. The method of claim 1, wherein creating a combination web page includes: 

retrieving current versions of the first web page and the second web page; 
selecting the user's chosen elements from the current version of the first and 
second web pages; and 

creating the combination web page that includes the chosen elements. 

3. The method of claim 1, wherein the combination web page includes only the 
chosen elements. 

4. The method of claim 1, wherein allowing the user to choose a subset of elements 
includes: 

adding selection-enabling information to the first and second web pages; 

sending the first and second web pages including the selection-enabling 
information to the user's browser; and 

receiving an indication that the user has selected at least one element of the 
first and one element of the second web page. 

5. The method of claim 1, wherein the combination web page is displayed on a client 

system. 

6. The method of claim 5, wherein the client system is a personal computer. 
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7. The method of claim 5, wherein the client system is a personal digital assistant 

device. 

8. The method of claim 5, wherein the client system is a cellular telephone having a 
5 display. 

9. The method of claim 5, wherein the client system is an alphanumeric paging 

device. 

10 10. The method of claim 5, wherein the client system is a web-enabled device. 

11. The method of claim 1, wherein the user first forms short web pages and 
combines the short web pages to form the combination web page. 

15 1 2. The method of claim 1 , wherein at least one of the first and second web pages is a 

world wide web page. 

13. The method of claim 1, wherein at least one of the first and second web pages is 
specified in a hypertext markup language. 

20 

14. A method for creating a combination web page, comprising: 

storing in a memory selection information specifying the elements on a 
combination web page, the combination web page being based on at least two original web 
pages; 

25 retrieving the original web pages upon which the combination web page is 

based; and 

creating the combination web page from elements on the original web pages in 
accordance with the selection information. 

30 15. The method of claim 14, wherein the combination web page is displayed on a 

client system. 
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16. The method of claim 15, wherein the client system is a personal computer. 

17. The method of claim 15, wherein the client system is a personal digital assistant 

device. 

18. The method of claim 15, wherein the client system is a cellular telephone. 

19. The method of claim 15, wherein the client system is an alphanumeric paging 

device. 

20. The method of claim 15, wherein the client system is a web-enabled device. 

21 . The method of claim 14, wherein the user first creates short pages and then 
combines the short pages to form the combination web page. 

22. The method of claim 14, wherein at least one of the first and second web pages is 
a world wide web page. 

23. The method of claim 14, wherein at least one of the first and second web pages is 
specified in a hypertext markup language. 

24. A computer-implemented method performed by a server data processing system, 
comprising: 

receiving, from a client, a request for multiple web pages; 

retrieving the multiple web pages; 

sending the requested multiple web pages to the client; 

receiving, from the client, selection information for the requested multiple web 
pages, the selection information indicating a subset of the information of the web pages that is 
smaller than the set of all information on the web pages; and 

storing the selection information in the server data processing system. 
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25. The method of claim 24, further comprising, by the server data processing 

system: 

splitting the retrieved web pages into page elements, by the server data 
5 processing system; and 

creating a new version of the retrieved web pages, the new version of the web 
pages including selection-enabling information, 

wherein sending the requested web pages to the client includes sending the 
new version of the retrieved web pages that includes the selection-enabling information. 

10 

26. The method of claim 24, 

wherein the requested web pages sent to the client do not include selection-enabling 
information, and 

wherein the selection-enabling information is added to the retrieved web pages by the 

15 client. 

27. A computer-implemented method performed by a server data processing system, 
comprising: 

receiving, from a client, a request for a user's combination web page; 
20 retrieving at least two web pages upon which the user's combination web page 

is based; 

selecting portions of the retrieved web pages in accordance with selection 
information of the user stored in the server data processing system; and 

sending the user's combination page, containing the selected portions of the 
25 retrieved web page to the user. 

28. The method of claim 27, wherein the selection information indicates whether 
portions of the retrieved web pages are shown or hidden in the shortpage. 

30 29. The method of claim 27, wherein receiving a request for a user's combination 

web page is performed at initialization of the user's browser. 
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30. The method of claim 27, further comprising: 

first allowing the user to create at least two short pages and then allowing the 
user to combine the short pages to form a combination web page. 

3 1 . A computer-implemented method performed by a client data processing system, 
comprising: 

sending, by a client, a request for at least two web pages; 
receiving the requested web pages; 

allowing the user to select portions of the received web pages as being hidden 
or shown, the hidden portions being indicated by selection information; and 

sending, to a server, the selection information for a combination web page formed by 
the at least two web pages. 

32. The method of claim 3 1 , further comprising: 

receiving at least two web page that are split into page elements, each page 
element having a selection-enabling information associated therewith; and 

receiving input from a user selecting at least one page element of each of the 
web pages to yield selection information; and 

sending the selection information to a server. 

33. The method of claim 1, wherein the shared combination web page is a shared 
portal web page accessible by more than one user. 

34. The method of claim 12, wherein the shared combination web page is a shared 
portal web page accessible by more than one user. 

35. The method of claim 20, wherein the shared combination web page is a shared 
portal web page accessible by more than one user. 
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36. The method of claim 23, wherein the shared combination web page is a shared 
portal web page accessible by more than one user. 

37. The method of claim 27, wherein the shared combination web page is a shared 
5 portal web page accessible by more than one user. 

38. An apparatus that creates a combination web page, comprising: 

software portions configured to allow a user to choose a subset of elements, 
some of which appear on a first web page and some of which appear on a second web page; 
10 software portions configured to save the user's choices; and 

software portions configured to create a combination web page that is based on 
the first web page and the second web page, and includes the elements chosen by the user in 
accordance with the user's saved choices. 

15 39. The apparatus of claim 38, wherein the user first forms short web pages and the 

apparatus combines the short web pages to form the combination web page. 

40. An apparatus that creates a combination web page, comprising: 

software portions configured to store in a memory selection information 
20 specifying the elements on a combination web page, the combination web page being based 
on at least two original web pages; 

software portions configured to retrieve the original web pages upon which the 
combination web page is based; and 

software portions configured to create the combination web page from 
25 elements on the original web pages in accordance with the selection information. 

41 . The apparatus of claim 40, wherein the user first creates short pages and then the 
apparatus combines the short pages to form the combination web page. 

30 42. A server apparatus, comprising: 
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software portions configured to receive, from a client, a request for multiple 

web pages; 

software portions configured to retrieve the multiple web pages; 

software portions configured to send the requested multiple web pages to the 

5 client; 

software portions configured to receive, from the client, selection information 
for the requested multiple web pages, the selection information indicating a subset of the 
information of the web pages that is smaller than the set of all information on the web pages; 
and 

10 software portions configured to store the selection information in the server 

data processing system. 

43. The apparatus of claim 42, further comprising: 

software portions configured to split the retrieved web pages into page 
1 5 elements, by the server data processing system; and 

software portions configured to create a new version of the retrieved web 
pages, the new version of the web pages including selection-enabling information, 

wherein sending the requested web pages to the client includes sending the 
new version of the retrieved web pages that includes the selection-enabling information. 

20 

44. A server apparatus, comprising: 

software portions configured to receive, from a client, a request for a user's 
combination web page; 

software portions configured to retrieve at least two web pages upon which the 
25 user's combination web page is based; 

software portions configured to select portions of the retrieved web pages in 
accordance with selection information of the user stored in the server data processing system; 
and 

software portions configured to send the user's combination page, containing 
30 the selected portions of the retrieved web page to the user. 
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45. A computer program product, comprising: 

a computer readable medium having computer executable instructions thereon that 
create a combination web page, including: 

computer program code devices configured to allow a user to choose a subset 
5 of elements, some of which appear on a first web page and some of which appear on a second 
web page; 

computer program code devices configured to save the user's choices; and 
computer program code devices configured to create a combination web page 
that is based on the first web page and the second web page, and includes the elements chosen 
10 by the user in accordance with the user's saved choices. 

46. A computer program product, comprising: 

a computer readable medium having computer executable instructions thereon that 
create a combination web page, including: 
15 computer program code devices configured to receive, from a client, a request 

for multiple web pages; 

computer program code devices configured to retrieve the multiple web pages; 
computer program code devices configured to send the requested multiple web 
pages to the client; 

20 computer program code devices configured to receive, from the client, 

selection information for the requested multiple web pages, the selection information 
indicating a subset of the information of the web pages that is smaller than the set of all 
information on the web pages; and 

computer program code devices configured to store the selection information 

25 in the server data processing system. 

47. A computer program product, comprising: 

a computer readable medium having computer executable instructions thereon that 
form a combination web page, including: 
30 computer program code devices configured to receive, from a client, a request 

for a user's combination web page; 
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computer program code devices configured to retrieve at least two web pages 
upon which the user's combination web page is based; 

computer program code devices configured to select portions of the retrieved 
web pages in accordance with selection information of the user stored in the server data 
5 processing system; and 

computer program code devices configured to send the user's combination 
page, containing the selected portions of the retrieved web page to the user. 
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<html> 
<head> 

<title>START ?age</title> 
</head> 

<script Language-" JavaScripts function ButtonClicked(buttonName) 

{ 

if (document .main form . txtURL . value « ' ') 

{ 

alert ( 1 Please enter a URL. ' ) ; 
return false; 

} 

else 

{ 

document .main_f orm. cznAct ion. value = buttonName ; 
return true; 

} 
} 

</ script > 



<body> 

<font size=" -1" color="#2244f f "> 

<pxf ont size= " - 1 " xA href = "h':tp : //shortpage . com: 9999/UserName-lma 
jerus&ProcName=Notif Page" target =" _t op" ><f ont color="#2244f f ">Noti 
fications Page</fontx/A> - <A href =" http://shortpage.com: 99 9 9 /Use 
rName=^lmajerus^£?rocName=S7AJlT_F ,, target="_top" xfont color= H #2244f 
f">Edit Prof ile</fontx/A> - <.A href = "http : //shortpage . com: 9999/Us 
erName=lmajerus&ProcMame=Kelpf:Index=3£ t Browser=l ,t targe t = ,, _top M xfo 
nt color="#2244ff " >Help</f onn : :/Ax/font> 
< ! END OF NAVIGATION BAR 

</f ont > </p> 

<h2 align=" center" >lmajer. -<3 • s START page</h2> 
<font size="-l" color="#00C0FF" > 

<px/fontx/p> 

<form action="http: //sr<u; page. com: 9 999/UserName=lmajerus&ProcName 
=WizardAction&?lace=5tart" .."V'.hoda" POST" name=" mam_form u 
onSubmit =" if ( txtURL . value == • ■){ alert (' Please enter a URL. 
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' ); return false; }else if (btnAction. value == 1 invalid 1 ){ bt 
nAct ion .value ■ 1 Browse » ; return true ? } " > 

<input type- 11 hidden 11 name«» btnAction" value=" invalid" ><p>Address 
<input type="text" 

size= ,, 60" name="txtURL" value>fcnbsp; < input type= n submit" name= " 
btnl 11 value= " Browse " 

onclick^" return ButtonClicked ( 'Browse 1 ) ; "></p> 

<pxinput type«" submit" name=»btn M value-" Create Shortpage" 

onClick= "return ButtonClicked ( 'Create Shortpage •);" > <input type 
= " submit" name= "btn" 

value="Create Notification" onClick=" return ButtonClicked ( 'Creat 
e Notification 1 ) ; "> 

&nbsp ; Scnbsp ; fidibsp ; fcnbsp ; &nbsp ; &nbsp ; &nbsp ; &nbsp ; &nbsp ; &nbsp ; &nbs 
p; < input 

type- "submit" namea |, btn" value=" Create ComboPage" 

onClick= "btnAction. value = fcquoc;Create ComboPage&quot: ; ; submit ( 
); return false; "> </p> 

<hr> 
</ form> 

< script Languages" JavaScript 
function DoAct ion (type , id) 
{ 

if (document . second_f orm. btnAction [document . second_f orm. btnAction. 
selectedlndex] .value s= delete 1 ) 
{ 

doDelete = confirm ( 1 Delete this ' + type + » ?•); 
if (doDelete) 

{ 

document . second_£orm. txt ID. value = id; 
document . second_form. submit ( ) ; 

} 

} 

else 

{ 

document, second_form.txt ID. value = id; 
document . second form, submit ( ) ; 

} 

return false; 

} 

</script> 
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=WizardAction&PlacesStart" methods "GET" names »second_f orm«> 
<input type= n hidden" r.ame=" txtlD" valuextable widths" 100%" > 
<tr valigns»top" > 

< td width= " 1 6 % " > <h3 >Ac t ion< /h3 > 
<pxselect name="btnAction" size= ,, 4 w > 
<option value= "Go" selected>Go</option> 
< opt ion value « " Edi t " > Edi t < / op t ion> 
<option value="Options">Options</option> 
<option value= "Delete" >Delete</option> 
</selectxl-- This is not a button but using the same name m 
akes things very convenient --xbr> 
</p> 

<p>New Folder :<br> 

<input type«"text" name="NewFolderName" size="9"> <br> 
<input type="suJbnut" values " Create 1 " name= n btnNewFolder" x/p 

> 

<p>fcnbsp; </td> 

<td width="84%"xtable width=100%xtr valign=top> 
<td width=33%xa href =http://shortpage. com: 9999/UserNameslmajerus& 
ProcNamesFolderOp&OpCodesCollapsefi t FolderIDsii6761&LoopBackshttp%3A 
%2F%2Fshortpage.com%3A9999%2FUserName%3Dlmajerus%26ProcName%3DStar 
tPageximg srcshttp: //www. shortware.com/images/minus_button.gif bo 
rdersOx/axbigxfont color= "#009900 ">ShortPages</f ontx/bigxBR> 
<A href ="http: //shortpage. com: 9999/UserNameslmajerus&ProcName-P_Ge 
tPagelot&ID=89115" onClicks ■ return DoAction( "ShortPage" , 89115)7' > 
< font colors » #2244 ff " >www . uspto . gov< /f one ></AxBR> 

<A href ="http: //shortpage. com: 9999/UserNameslmajerus£cProcName=P_Ge 
tPageletficIDs89117" onClicks ■ return DoAct ion ( "ShortPage" , 89117) ;■> 
< font colors " #2244 f f " >www . uspto . gov/ cgi -bin/phone/ptophone< / font x 
/AxBR> 

<A hre-. http://shortpage.com: 9999/UserName=lmajerus&ProcNameoP_G:i 
tPagex->fi t ID=89126" onClick= ' return DoAction ( "ShortPage" , 89126) ;'> 
<font colors" #2244 f f ">164 . 195 . 100 . 11/netahtml/search-bool . html</f o 
ntx/AxBR> 

<A href ■ " http : / / shortpage . com : 9 9 9 9 /UserNameslma j erus ScProcNe'nes P_Ge 
-PngeletS t ID=89128" onClick= » return DoAction ( "ShortPage" , 891-;^ :•> 
<for:~ color="#2244ff ">www. uspto. gov</fontx/AxBR> 
<A href s»http : / /shortpage . com: 9999/UserName=lmajerus&ProcName«P_Ge 
tPagelet&ID=89129" onClick= ' return DoAction ( "ShortPage" , 89129) ; ' > 
< font colors " #2 24 4 f f " >www . uspto . gov< / fontx/AxBR> 

-A href s"http : //shortpage .com: 9999/UserNameslmajerusScProcName-^ Ge 
tPa^j? it&ID=8 913 0" onClicks • return DoAction (" ShortPage " , 89130);*. 
<font colors" #22 44f f ">www. uspto. gov</ font x/AxBR> 
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<A href -"http : / /shortpage .com: 9999/UserName-lmajerus&ProcName«P_Ge 

tPagelet&ID»89133 M onclick- • return DoAct ion ( "Short Page , 89133) ;'> 

< font color- « #2244 f f " >www . opt ipat . com< / f ont x /AxBR> 

<A href =»http: //shortpage. com: 9999/UserName=lmajerusfi t ProcNameoP_Ge 

tPagelet&ID=111525" onClick- 1 return DoAct ion ("Short Page" , 111525); 

1 xfont color= u #2244ff ">www.usoto.gov</fontx/AxBR> 

<BR> 

<a href =http: / /shortpage. com: 9999/UserName=lmajerus£ProcName»Folde 

rOp&OpCodeoExpand&FolderID=116765ficLoopBack=http%3A%2F%2Fshortpage. 

com%3A9999%2FUserName%3Dlmajeru3%26ProcName%3DStartPageximg src=h 

t tp : / / www . shortware . com/ images / addjout ton .gif border =0 > < / axbigx f 

ont color="#009900">test</fontx/bigxBR> 

<BR> 

</td> 

<td width=33%xa href =http : //shortpage . com: 9999/UserName=Imajerus& 
ProcName»FolderOpficOpCode=CollapseficFolderIDoll6762&LoopBack=http%3A 
%2F%2Fshortpage.com%3A9999%2FUserName%3Dlmaj erus%26ProcName%3DStar 
tPageximg src=http : //www. shortware . com/ images /minus_but ton. gif bo 
rder=Ox/axbigxfont color-" #009900 ">ComboPages</f ont x/bigxBR> 
<A href = "http : / /shortpage . com: 9999/UserName=lmajerus&ProcName-P_Ge 
tPagelet&ID=89118" onclick- 1 return DoActionC'ComboPage" , 89118) ;■> 
<font color="#2244ff ">ComboPage #l</f ontx/AxBR> 

< A hre f = " http : / / shortpage . com : 9 9 9 9 /UserName- lma j erus &P rocName»P_Ge 

tPagelet&ID=103560 M onclick- • return DoAction( "ComboPage" , 103560); 

1 xf ont color- « #2244f f " > < /f ontx/AxBR> 

<BR> 

</td> 

<td width»33%xa href =http : //shortpage . com: 9999/UserName=lmaj erusfc 
ProcName=FolderOp&OpCode--Collapse6cFolderID=115763£cLoopBack=http%3A 
%2F%2Fshortpage.com%3A99?9%2FUserName%3Dlmajerus%2 6ProcName%3DStar 
tPagex img src=http : //w w< . shortware . com/ images /minus_but ton. gif bo 
rder=0x /axbigx font color- "#009900 " ^Notifications*:/ font x/bigxB 
R> 

<A href = n http: //shortpage. com: 9999/UserName=lmajerusficProcName-P_Ge 

tPagelet&ID=891i: » onClick- • return DoActionC'Notif ication" , 89111) 

; 1 ><f one color="#2; l :ff " >www . uspto , gov< / font >< / Ax BR> 

<BR> 

</td> 

</trx/table> 
</td> 

</tr> 
</table> 
</f orm> 
</body> 
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